![untitled](data:image/jpeg;base64,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)

**United** International **University** (UIU)

Dept. of Electrical and Electronic Engineering (EEE)

# **Course**: VLSI Design Lab (EEE 442)

**Experiment 3: Synthesis of Counter using Verilog**

Introduction:

1. Switch to csh, this will also setup your cadence tools environment variables

* csh

1. Create the lab directory and few other sub-directories under your work area:

* mkdir lab3
* cd lab3
* mkdir simulation synthesis rtl lib constraints
* cd simulation

1. Use an editor (vi, nedit, gedit etc.) to write behavioral model of an 8-bit counter

* vi cntr8bit.v

1. Use an editor to write a test bench Verilog code for your counter

* vi cntr8bit\_tb.v

1. Use Incisive Enterprise Simulator (IES) to verify that the counter is working properly. Follow the steps from previous labs to complete the simulation.
2. When you are satisfied with your simulation, copy the counter module into the rtl sub-directory.

* cp cntr8bit.v ../rtl/

1. Go to lib/ and copy the slow.lib and fast.lib files from ~sahmed/eee442/lab3/lib/

* cd ../lib
* cp ~sahmed/eee442/lab3/lib/\*.lib . (don’t forget the dot(.) at the end)

1. Go to synthesis/ and create the RC synthesis script (rc\_script.tcl)

* cd ../synthesis
* vi rc\_script.tcl

1. Sample contents of rc\_script.tcl file:

set\_attr lib\_search\_path ../lib/

set\_attr hdl\_search\_path ../rtl/

set\_attr library slow.lib

read\_hdl cntr8bit.v

elaborate

read\_sdc ../constraints/cntr8bit.g

synthesize -to\_mapped -effort medium

write\_hdl > cntr8bit\_netlist.v

write\_sdc > cntr8bit.sdc

1. Go to constraints/ and create the design constraint file (cntr8bit.g)

* cd ../constraints
* vi cntr8bit.g

1. Sample contents of cntr8bit.g file:

create\_clock -name clk -period 10 -waveform {0 5} [get\_ports "clk"]

set\_clock\_transition -rise 0.1 [get\_clocks "clk"]

set\_clock\_transition -fall 0.1 [get\_clocks "clk"]

set\_clock\_uncertainty 0.1 [get\_ports "clk"]

set\_input\_delay -max 1.0 [get\_ports "rst"] -clock [get\_clocks "clk"]

set\_output\_delay -max 1.0 [get\_ports "count"] -clock [get\_clocks "clk"]

1. Move back to the synthesis/ and invoke RTL Compiler along with the rc\_script.tcl file to synthesize the netlist.

* cd ../synthesis
* rc –f rc\_script.tcl

1. While performing synthesis, always check the RC terminal whether the tool is reporting any error.
2. After synthesis, launch the GUI to see the schematic in the ‘rc’ terminal.

* gui\_show

1. After checking the schematic, if you are satisfied, close the GUI in the ‘rc’ terminal.

* gui\_hide

1. Use ‘report’ command to write out the results

* report timing (reports the timing details)
* report power (write the power report)
* report (to know different reports you can dump out from RC)

1. After completing synthesis, write out gate level netlist and SDC constraints for Physical Design.

* write\_hdl > cntr8bit\_netlist.v
* write\_sdc > cntr8bit.sdc

(Both the above commands are part of the rc\_script.tcl file, so they are already executed)

1. Close the RTL Compiler

* exit

1. Open the Cadence Help gui, expand the RTL Compiler and double click on any sub-menu you would like to explore.

* cdnshelp &

1. …